<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>菜单和权限管理</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <link rel="stylesheet" href="../../../lib/layui-v2.5.5/css/layui.css" media="all">
	  <link rel="stylesheet" href="../../../lib/font-awesome-4.7.0/css/font-awesome.min.css" media="all">
    <link rel="stylesheet" href="../../../css/public.css" media="all">
</head>
<body>
<div class="layuimini-container">
    <div class="layuimini-main">
		<!-- 搜索开始 -->
        <fieldset class="layui-elem-field layuimini-search">
            <legend>搜索信息</legend>
            <div style="margin: 10px 10px 10px 10px">
                <form class="layui-form layui-form-pane" action="" id="searchForm">
                    <div class="layui-form-item">
                        <div class="layui-inline">
                            <label class="layui-form-label">关键字</label>
                            <div class="layui-input-inline">
                                <input type="text" name="title" id="search_title" autocomplete="off" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-inline">
                            <div class="layui-input-inline">
                              <a class="layui-btn " lay-submit=""  lay-filter="data-search-btn"><label class="layui-icon layui-icon-search"></label>搜索</a>
                              <a class="layui-btn layui-btn-warm" onclick="javascript:$('#searchForm')[0].reset()" lay-filter="data-search-btn"><label class="layui-icon layui-icon-refresh"></label>重置</a> 
                            </div>
                        </div>
                    </div>
                </form>
            </div>
        </fieldset>
		<!-- 搜索开始 -->

	<!--表格开始-->
	    <a class="layui-btn" href="javascript:void(0)" id="addMenuBtn"><span class="layui-icon layui-icon-add-1"></span>添加</a>
        <table class="layui-hide" id="menuTable" lay-filter="menuTable"></table>
     <!--   <script type="text/html" id="menuToolBar">
			 <a class="layui-btn layui-btn-sm " lay-event="addmenu">添加</a>
            <a class="layui-btn layui-btn-sm layui-btn-danger data-count-delete" lay-event="batchdelete">批量删除</a>
        </script> -->
		<script type="text/html" id="menuTableBar">
			 <a class="layui-btn layui-btn-xs layui-btn-warm   data-count-delete" lay-event="update">修改</a>
		     <a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="delete">删除</a>
		</script>
		
		<script type="text/html" id="spreadTpl">
		  <!-- 这里的 checked 的状态只是演示 -->
		  <input type="checkbox" name="spread" value="{{d.id}}" lay-skin="switch" lay-text="展开|不展开" lay-filter="spreadSwitch" {{ d.spread == 1 ? 'checked' : '' }}>
		</script>
		
		<script type="text/html" id="availableTpl">
		  <!-- 这里的 checked 的状态只是演示 -->
		  <input type="checkbox" name="available" value="{{d.id}}" lay-skin="switch" lay-text="可用|不可用" lay-filter="availableSwitch" {{ d.available == 1 ? 'checked' : '' }}>
		</script>
		<!--表格结束-->
		
		<!-- 增加修改弹出层开始 -->
		<div id="addOrUpdateDiv" style="display: none; padding: 0.375rem;" >
			<form method="post" class="layui-form layui-form-pane" lay-filter="dataFrm" id="dataFrm">
				
				  <div class="layui-form-item">
				    <label class="layui-form-label">菜单类型</label>
				    <div class="layui-input-block">
				      <input type="radio" name="type" value="topmenu"    lay-filter="typeFilter" title="顶部菜单" >
				      <input type="radio" name="type" value="leftmenu"   lay-filter="typeFilter" title="左部菜单" checked="">
				      <input type="radio" name="type" value="permission" lay-filter="typeFilter" title="按钮权限">
				    </div>
				  </div>
				
				  <div class="layui-form-item item_leftmenu item_permission">
				    <label class="layui-form-label">父级菜单</label>
				    <div class="layui-input-inline" >
					  <input type="hidden" name="id" />
					  <input name="pid" hidden="hidden" id="p_id" />
				      <input type="text" name="pid_name" id="p_name" readonly="readonly" autocomplete="off" placeholder="请选择父级菜单和权限" class="layui-input">
				    </div>
					<div class="layui-input-block">
						<a class="layui-btn layui-btn-warm" id="doSelectMenu"><label class="layui-icon layui-icon-male"></label>选择 </a>
					</div>
				  </div>
				  
				  <div class="layui-form-item">
				    <label class="layui-form-label">名称</label>
				    <div class="layui-input-block">
				      <input type="text" name="title" id="name" lay-verify="required" autocomplete="off" placeholder="请选择菜单和权限名称" class="layui-input">
				    </div>
				  </div>
				  
				  <div class="layui-form-item">
				    <label class="layui-form-label">编码</label>
				    <div class="layui-input-block">						
				      <input type="text" name="typecode"  autocomplete="off" placeholder="请输入菜单和权限地址" class="layui-input">
				    </div>
				  </div>
				  
				  <div class="layui-form-item  item_leftmenu item_topmenu">
				    <label class="layui-form-label ">图标</label>
				    <div class="layui-input-block">						
				      <input type="text" name="icon"  autocomplete="off" placeholder="请输入菜单和权限地址" class="layui-input">
				    </div>
				  </div>
				  
				<div class="layui-form-item item_leftmenu">
				  <label class="layui-form-label ">链接地址</label>
				  <div class="layui-input-block">
				     <input type="text" name="href"  autocomplete="off" placeholder="请输入菜单和权限地址" class="layui-input">
				  </div>
				</div>
				
				<div class="layui-form-item  item_leftmenu">
				  <label class="layui-form-label ">TARGET</label>
				  <div class="layui-input-block">
				    <input type="radio" name="target" value="_self" title="_self" checked="">
				    <input type="radio" name="target" value="_blank" title="_blank">
				  </div>
				</div>
				
				<div class="layui-form-item">
				  <label class="layui-form-label">排序码</label>
				  <div class="layui-input-block">
				   <input type="text" name="ordernum" id="ordernum" autocomplete="off" placeholder="请输入菜单和权限地址" class="layui-input">
				  </div>
				</div>
			
					
			 
			  <div class="layui-form-item">
				<div class="layui-input-block" style="text-align: center;">
					<a class="layui-btn " lay-submit=""  lay-filter="doSubmit"><label class="layui-icon layui-icon-release"></label>提交</a>
					<a class="layui-btn layui-btn-warm" onclick="javascript:$('#dataFrm')[0].reset()" lay-filter="data-search-btn"><label class="layui-icon layui-icon-refresh"></label>重置</a>
				</div>
			  </div>
				  
			</form>
		</div>
	
    </div>
</div>
<script src="../../../lib/jquery-3.4.1/jquery-3.4.1.min.js" charset="utf-8"></script>
<script src="../../../lib/layui-v2.5.5/layui.js" charset="utf-8"></script>
<script src="../../../js/lay-config.js?v=1.0.4" charset="utf-8"></script>
<script src="../../../lib/jq-module/jquery.particleground.min.js" charset="utf-8"></script>
<script src="../../../lib/common/jquery.cookie.min.js" charset="utf-8"></script>
<script src="../../../lib/common/common.js " charset="utf-8"></script>
<script src="../../../lib/common/selectLayer.js " charset="utf-8"></script>



<script>
    layui.use(['form', 'table','layer','treeTable','laydate'], function () {
        var form = layui.form;
        var table = layui.table;
		var laydate = layui.laydate;
		var layer = layui.layer;
		var treeTable = layui.treeTable;
     var tableObj=  treeTable.render({
		    tree: {
				iconIndex: 1,                // 折叠图标显示在第几列
				idName: 'id',       // 自定义id字段的名称
				pidName: 'pid',         // 自定义标识是否还有子节点的字段名称
				isPidData: true              ,// 是否是pid形式数据
				openName: 'spread'  // 自定义默认展开的字段名
			},
			elem: '#menuTable',
			cellMinWidth:true,
			width:"100%",
            cols: [
                {type: "numbers"},
				{field: 'title',title: '菜单或权限名称',width:200},
                {field: 'id', title: 'ID', align:"center",width:50},
                {field: 'pid', title: 'PID', align:"center",width:50},      
                {field: 'type',title: '类型', align: "center",width:90,templet: function (d) {
                        if (d.type == 'topmenu') {
                            return '<span class="layui-badge layui-bg-red">顶部菜单</span>';
                        }
                        if (d.type == 'leftmenu') {
                            return '<span class="layui-badge layui-bg-blue">左侧菜单</span>';
                        } else {
                            return '<span class="layui-badge-rim layui-bg-green">权限菜单</span>';
                        }
                    }},
				{field: 'href',title: '地址', align: "center",width:120},
				{field: 'typecode',title: '编码', align: "center",width:100},
                {field: 'icon', title: '图标', align: "center",width:50,templet:function(d){
					return "<span class='"+d.icon+"'><span>"
				}},
                {field: 'target', title: 'TARGET', align: "center",width:50},
				{field: 'ordernum', title: '排序码', align: "center",width:50},
				
				{field: 'spread', title: '是否展开', align: "center",width:100,templet: '#spreadTpl'},
				{field: 'available', title: '是否可用', align: "center",width:100,templet:'#availableTpl'},
                {title: '操作',templet: '#menuTableBar', fixed: "right", align: "center"}
            ],
		    reqData: function(data, callback) {
				if(data==undefined){
					// 在这里写ajax请求，通过callback方法回调数据
					$.get(api+'menu/loadAllMenu', function (res) {
					 callback(res.data);
					 console.log(res.data)
					});
				}else{
					callback([])
				}
				
			}
        });
		
		

        // 监听搜索操作
        form.on('submit(data-search-btn)', function (data) {			
		      var title=$("#search_title").val();
			  if(title){
				  tableObj.filterData(title);
			  }else{
				  tableObj.reload();
			  }
            return false;
        });
		
		
		
		form.on('radio(typeFilter)', function(data){
		  // console.log(data.value); //被点击的radio的value值
		 		  $(".item_topmenu").show();
		 		  $(".item_leftmenu").show();
		 		  $(".item_permission").show();
		 		  if(data.value=='topmenu'){
		 			   $(".item_leftmenu").hide();
		 			   $(".item_permission").hide();
		 			   $(".item_topmenu").show();
		 		  }else if(data.value=='leftmenu'){
		 			  $(".item_permission").hide();
		 			  $(".item_topmenu").hide();
		 			  $(".item_leftmenu").show();
		 		  }else{
		 			  $(".item_leftmenu").hide();
		 			  $(".item_topmenu").hide();
		 			  $(".item_permission").show();
		 		  }
		}); 

	
	//监听添加按钮的事件
	$("#addMenuBtn").click(function(){
		openAddmenu();//打开添加的弹层
	})


		//打开弹出层
		var mainIndex;
		var url;
		function openAddmenu(){
			mainIndex=layer.open({
				 type: 1,
				 title:'添加菜单和权限',
				 content:$("#addOrUpdateDiv"),
				 area:['800px','600px'],
				 success:function(index){
					 url=api+"menu/addMenu";
					 //重置表单
					 $("#dataFrm")[0].reset();
					//加载最大排序码
					$.get(api+"menu/queryMenuMaxOrderNum",function(res){
						// alert(JSON.stringify(res.data))
						$("#ordernum").val(res.data);
					})
					$(".item_permission").hide();
					$(".item_topmenu").hide();
					$(".item_leftmenu").show();
				 }
			});
		}
		
		function openUpdatemenu(data){
			mainIndex=layer.open({
				 type: 1,
				 title:'修改['+data.title+']菜单和权限',
				 content:$("#addOrUpdateDiv"),
				 area:['800px','600px'],
				 success:function(index){
					 url=api+"menu/updateMenu";
					 // if(data.pid==0){
						//  $("#div_pid").hide();
					 // }else{
						//  $("#div_pid").show();
					 // }
					 //装载数据表格
					 form.val("dataFrm",data);
					 $.get(api+"menu/getMenuById",{id:data.pid},function(res){
					 	console.log(res.data.title)
					 	$("#p_name").val(res.data.title);
					 }) 
					 if(data.type=='topmenu'){
						   $(".item_leftmenu").hide();
						   $(".item_permission").hide();
						   $(".item_topmenu").show();
					 }else if(data.type=='leftmenu'){
						  $(".item_permission").hide();
						  $(".item_topmenu").hide();
						  $(".item_leftmenu").show();
					 }else{
						  $(".item_leftmenu").hide();
						  $(".item_topmenu").hide();
						  $(".item_permission").show();
					 } 
					 
					
					
				 }
			});
		}
		
		
		// 提交数据
		form.on("submit(doSubmit)",function(data){
		    var params=$("#dataFrm").serialize();
			// alert(params);
			$.post(url,params,function(res){
				layer.msg(res.msg);
				if(res.code==200){
					tableObj.reload();
				}
				//关闭弹出层
				layer.close(mainIndex);
			})
			
			return false;
		}) 
		
    
		//单行删除和修改
        treeTable.on('tool(menuTable)', function (obj) {
            var data = obj.data;
            if (obj.event === 'delete') {
				$.get(api+"menu/getMenuChildCountById",{id:data.id},function(res1){
					if(res1.data>=1){
						layer.msg("此菜单和权限下有子菜单和权限，请先删除子菜单和权限")
						return;
					}else{
						layer.confirm('真的删除行么', function (index) {
							$.post(
							api+"menu/deleteMenu",
							{id:data.id},
						function(res){
							 layer.msg(res.msg);
							 obj.del();
							 layer.close(index);
							})                 
						});	
					}
				})
				
              
            }else if(obj.event==="update"){
				openUpdatemenu(data);
			}
        });
	
	
	//监听是否展开事件
	form.on('switch(spreadSwitch)', function(obj){
		$.post(api+"menu/updateMenu",{id:this.value,spread:obj.elem.checked?1:0},function(res){
			layer.msg(res.msg);
			tableObj.reload();
		});
	  });
	  //监听是否可用事件
	  form.on('switch(availableSwitch)', function(obj){
		  $.post(api+"menu/updateMenu",{id:this.value,available:obj.elem.checked?1:0},function(res){
		  	layer.msg(res.msg);
		  	tableObj.reload();
		  });
	    });
		
		
  //监听菜单和权限选择的事件，打开菜单和权限选择的弹出层
    $("#doSelectMenu").click(function(){
		var p_id=$("#p_id").val();
		var p_name=$("#p_name").val();
		openMenuSelecter(p_id,function(id,name){
			$("#p_id").val(id);
			$("#p_name").val(name);
		})
	})
	
	

		
		
    });
</script>
<script>

</script>

</body>
</html>